Topics |
|
PostScript is a device-independent programming language for describing the appearance of text and graphics on a printed page. PostScript is an interpreted language, which means that when a printer or other interpreter looks at the file it executes the instructions one by one. There is no compilation step.
A PostScript file is an ordinary ASCII file. The first line of every PostScript file begins with %! usually followed by the version identifier: PS-Adobe 2.0. Comments begin with a percent sign % and end with a new line character.
The PostScript interpreter manages a dictionary stack, an operand stack, an execution stack, and a graphics state stack. Each stack is processed last-in, first-out (LIFO). Most PostScript operators use the operand stack-for example; the statement for adding two numbers is as follows:
2 3 add
This statement "pushes" a 2 and then a 3 onto the stack, and then the add operator "pops" both numbers off and then pushes the result (5) back onto the stack. PostScript uses postfix notation, where the operands (2 and 3) precede the operators (add).
The unit of measurement in PostScript is referred to as a point. There are 72 points per inch by default. Thus, a letter-size sheet of paper measures 612 by 792 points, with the origin (0,0) in the lower left corner of the page. PostScript operators allow you to manipulate the coordinate system using operators such as translate, scale, rotate, and so on.
The current point is the reference point used by many PostScript commands, including the commands for placing text on the page. Once set, the current point remains fixed in position on the paper until moved again. The default coordinate system originates (zero-zero point) at the lower left corner of the page. The X-axis increases towards the right and the Y-axis increase towards the top of the page. The initial zero-zero point is always the physical corner of the paper, even if the printer can't print all the way to the edge of the page. By default, distances are specified in PostScript points (1/72 of an inch.) This is true only if the default coordinate system is used. The location of the origin, the units for measurements, and even the direction of the axis may be changed by the programmer.
The PostScriptDrv class is used to create postscript documents. This version prints postscript documents to a file or the stdout. The default coordinate system is used for all PostScript operations and all distances are calculated in increments of 1/72 of an inch.
PostScriptDrv::PostScriptDrv() - Default class constructor responsible for setting the default page description values and default fonts.
PostScriptDrv::~PostScriptDrv() - Class destructor that does nothing.
PostScriptDrv::PostScriptDrv(const PostScriptDrv &ob) - Class copy constructor used to copy construct a PostScriptDrv object.
PostScriptDrv &PostScriptDrv::operator=(const PostScriptDrv &ob) - Overloaded assignment operator used to assign the specified object to the object that invoked the call.
void PostScriptDrv::DocumentSetup(double LR_margin = 0, double TB_margin = 0, int man = 0) - Public member function used to calculate the x and y positions, lines per page and columns for landscape and portrait modes. The left/right and top/bottom margin offsets will not be used if left/right or top/bottom margins are not enabled. If man is true the line per page will be set to max lines per page for UNIX man pages produced by nroff. Nroff is used to format man pages under most variants of UNIX.
void PostScriptDrv::SetFont(PSFonts font, double size) - Public member function used to set the document font. PSFonts is an enumeration defined in the PostScriptDrv class used to select a font family.
void PostScriptDrv::SetPaperSize(PSPaperSizes size) - Public member function used to set the paper size for this document. PSPaperSizes is an enumeration defined in the PostScriptDrv class used to set the paper size.
void PostScriptDrv::UseLRMargin() - Public member function used to enable left and right margins.
void PostScriptDrv::UseTBMargin() - Public member function used to enable top and bottom margins.
void PostScriptDrv::NoMargins() - Public member function used to disable left/right and top/bottom margins.
void PostScriptDrv::LandScapeMode() - Public member function used to enable landscape mode.
void PostScriptDrv::PortraitMode() - Public member function used to enable portrait mode.
void PostScriptDrv::Copies(int num) - Public member function used to set the number of copies that will be printed.
void PostScriptDrv::SetTabStop(int num) - Public member function used to set the tab size.
int PostScriptDrv::StringLen(char *s, int charWidth) - Public member function used to convert a string's length to PostScript points.
int PostScriptDrv::StringLen(const char *s, int charWidth) - Public member function used to convert a string's length to PostScript points.
double PostScriptDrv::CharsPerInch() - Public member function that returns the characters per inch based on the selected font size. The number of characters per inch is calculated by dividing the pixels per inch by the character width of the selected font.
double PostScriptDrv::CharWidth() - Public member function that returns the character width of the selected font. The character width of a COURIER font is calculated by multiplying .6 by the selected font size. All the other PostScript fonts have a variable character width.
char *PostScriptDrv::TextFont() - Public member function that returns the name of the selected font family.
double PostScriptDrv::FontSize() - Public member function that returns the current font size.
int PostScriptDrv::PageWidth() - Public member function that returns the current page width in PostScript points, based on the selected paper size.
int PostScriptDrv::PageHeight() - Public member function that returns the current page height in PostScript points, based on the selected paper size.
int PostScriptDrv::LinesPerPage() - Public member function that returns the current lines per page, based on the selected font, paper size, margins, and orientation.
int PostScriptDrv::Columns() - Public member function that returns the current number of columns, based on the selected font, paper size, margins, and orientation.
int PostScriptDrv::StartX() - Public member function that returns the starting x position for each page.
int PostScriptDrv::StartY() - Public member function that returns the starting y position for each page.
int PostScriptDrv::NCopies() - Public member function that returns the current number of copies to be printed.
int PostScriptDrv::TabStop() - Public member function that returns the current tab setting.
int PostScriptDrv::UsingLRMargin() - Public member function that returns true if left and right margins are enabled.
int PostScriptDrv::UsingTBMargin() - Public member function that returns true if top and bottom margins are enabled.
int PostScriptDrv::GetMode() - Public member function that returns true if using landscape mode.
void PostScriptDrv::UseHeader() - Public member function used to enable a header and page number to be printed on each page.
int PostScriptDrv::UsingHeader() - Public member function that returns true if headers and page numbers are enabled.
char *PostScriptDrv::HeaderFont() - Public member function that returns the name of selected header font.
double PostScriptDrv::HeaderFontSize() - Public member function that returns the current size of the header font.
void PostScriptDrv::SetHeaderFont(PSFonts font, double size) - Public member function used to set the header font. PSFonts is an enumeration defined in the PostScriptDrv class used to select a font family.
void PostScriptDrv::SetDocumentName(char *s) - Public member function used to name this document. The document name will be printed on each page if the use of page headers is enabled.
void PostScriptDrv::SetDocumentName(const char *s) - Public member function used to name this document. The document name will be printed on each page if the use of page headers is enabled.
void PostScriptDrv::SetDateString(char *s) - Public member function used to add a date to this document. The date string will be printed on each page if the use of page headers is enabled.
void PostScriptDrv::SetDateString(const char *s) - Public member function used to add a date to this document. The date string will be printed on each page if the use of page headers is enabled.
void PostScriptDrv::DrawHeaderLine() - Public member function used to enable lines that will be printed below the page header and above the page number.
void PostScriptDrv::Epilogue(ostream &stream, int page_count) - Public member function used to write the PostScript epilogue to the specified stream when the end of document is reached.
void PostScriptDrv::EndPage(ostream &stream) - Public member function used to write the end of page sequence to the specified stream when the end of a page is reached.
void PostScriptDrv::StartPage(int n, ostream &stream) - Public member function used to write the start of page sequence to the specified stream each time a new page is started.
void PostScriptDrv::drawLine(ostream &stream, int points, int xpos, int ypos) - Public member function used to draw a line to the specified stream starting at the specified x and y positions. The number of PostScript points determines the length of the line.
void PostScriptDrv::drawThickLine(ostream &stream, int points, int xpos, int ypos) - Public member function used to draw a thick line to the specified stream starting at the specified x and y positions. The number of PostScript points determines the length of the line.
void PostScriptDrv::MoveTo(ostream &stream, int x, int y) - Public member function used to move to the specified x and y positions.
void PostScriptDrv::ChangeFont(ostream &stream, PSFonts font, double size) - Public member function used to change the current font. PSFonts is an enumeration defined in the PostScriptDrv class used to select a font family.
int PostScriptDrv::ConvertTextFile(ifstream &infile, ostream &stream, int wrap = 0, int cut = 1) - Public member function used to convert the specified ASCII document to a PostScript document. If wrap is true the line will wrap around the page if the number of columns are exceeded. If cut is true the line will be truncated to match the maximum number of columns set for this document. Returns true if successful.
int PostScriptDrv::ProcessText(char *in, ostream &stream, int cut = 1, int filter = 0) - Public member function used to process a line of text before printing it. If cut is true the line will be truncated to match the maximum number of columns for this line. If filter is true each line will be filtered for escape sequences and non-printable characters before the line is truncated. Returns true if successful.
int PostScriptDrv::PrintLine(char *in, ostream &stream) - Public member function used to print a line of text to the selected stream.
int PostScriptDrv::PrintLine(char *s, unsigned max_len, ofstream &stream) - Public member function used to print a line of text, up to the specified length, to the specified stream.
void PostScriptDrv::Prologue(ostream &stream, char *pn = 0, char *hn = 0, char *cd = 0, char *un = 0) - Public member function used to print the PostScript prologue to the specified stream. This indicates the start of the document. Arguments are: pn - Program Name, hn - Hostname, cd - Creation Date, un - Username. The arguments will be added to the prologue only if specified.
void PostScriptDrv::MediaSetup(ostream &stream, int duplex = 0, int manualfeed = 0, int use_tray = 0, int tray_number = 0) - Public member function used to set the physical sources and physical destinations for the media source and destination to be used by the printer. These settings are device dependent. The duplex option enables duplex printing if a duplex device is attached to the printer. Each pair of consecutive pages will be printed on opposite sides of a single sheet of paper. The manual feed option will feed the paper from the manual feed position. The tray options are used to select a specific paper tray to print from. The tray number indicates the actual paper tray. The correspondence between tray numbers and the actual positions is specific to each printer. Example: The HP LaserJet 5Si/5Si MX printer uses the following numbers to represent the actual paper trays: 0 = Tray 2, 1 = Tray 3, 2 = Envelope Feeder, 3 = Tray 1, 4 = Tray 4
void GetSystemTime(char *s, int full_month_name = 1) - Standalone function used to create a custom time string for PostScript page headers. If the full_month_name variable is false an abbreviated month name will be used instead of a full name, which is selected by default.
Most PostScript products include software to support 13 standard fonts based on the Courier, Times, Helvetica, and Symbol families. The following enumeration, defined in the PostScriptDrv class, is used to select a specific font:
enum PSFonts { COURIER, COURIER_BOLD, COURIER_OBLIQUE, COURIER_BOLD_OBLIQUE, TIMES, TIMES_BOLD, TIMES_ITALIC, TIMES_BOLD_ITALIC, HELV, HELV_BOLD, HELV_OBLIQUE, HELV_BOLD_OBLIQUE, SYMBOL };
The following enumeration, defined in the PostScriptDrv class, is used to select a specific paper size:
enum PSPaperSizes { // Non-metric Traditional Paper Sizes used in Canada and the // United States. Sheet sizes accommodate 1/8" (3 mm) head, // foot, and fore edge trim margins (width precedes height.) // Decimal inches multiplied by 25.4 to convert to approximate mm. // N.B. fractional mm measures must be rounded to the nearest // whole number. LETTER_SIZE, // 8.5 x 11 inches LEGAL_SIZE, // 8.5 x 14 inches TABLOID_SIZE, // 11 x 17 inches // ISO/DIN and JIS Standard Paper Sizes Trim sizes in mm. // Width precedes height. Sheet sizes accommodate 3mm head, // foot, and fore edge trim margins. To convert to approximate // decimal inches, divide measures by 25.4. A3_SIZE, // 297mm x 420mm (11.70" X 16.55") A4_SIZE // 210mm x 297mm (8.27" X 11.70") };